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METHOD TO VALIDATE SYSTEM CONFIGURATION 
Field Of The Invention 

The present invention relates to a method to validate the configuration of a data storage and 
retrieval system. 

5 Background Of The Invention 

The last ten years have v^itnessed a ten-thousand fold increase in computer performance. 
At the same time, requirements are increasing for more robust, highly available, disaster-tolerant 
computing resources. Nevertheless, computing resources continue to be pushed to their limits, 
with performance problems often traceable to the connectivity and performance of input/output 
subsystems. 

H A wide variety of input/output (I/O) devices with various performance capabilities may 

W 

%| be included in a data storage and retrieval system. Examples of 1/0 devices include keyboards, 
yJ pointing devices, scanners, disk drives, CD-ROM drives, printers, display monitors, local area 

network (LAN) adapters, FAX/modem boards, sound boards, etc. I/O devices are produced by 
^ many different manufacturers and come in various models with varying operational 
p characteristics. The number of possible combinations of I/O devices in a data storage and 

retrieval system may be very large. 

In order for the components of a data storage and retrieval system to function together 

properly and optimally, system configuration information is provided during the power-on self- 
20 test (POST) and system initialization routines executed when the system is first powered-up or 

reset. The system configuration information is used to initialize the various components of the 

system. Device registers are set, device parameters are loaded, interrupt vectors are created, etc. 
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Computer operating system and/or other system management software is then configured in 
accordance with the system configuration information. 

A "bus" in a digital computer system is a circuit consisting of parallel conductors for 
interconnecting major components of a digital computer which transfers electric signals from one 
5 component connected to the bus to another component connected to the bus. Buses of various 
different types are present in virtually every digital computer. One particular bus, called the 
Small Computer System Interface ("SCSI") bus, is used widely for coupling to a digital 
computer various I/O devices, e.g. disk drives. Digital Audio Tape ("DAT") drives, Compact 
Disk Read Only Memory ("CD ROM") drives, optical storage drives, printers, scanners, and 
ftO even photo-composers. 

to The SCSI bus is a local Input/Output ("I/O") bus that can be operated over a wide range 

f";' of data rates. The primary object of the SCSI bus interface is to provide host computers with 

ssr; 

fi device independence within a class of devices. Accordingly, different disk drives, tape drives, 
^ printers, optical media drives, and other devices can be added to a host computer without 
Qi3 requiring modifications to generic system hardware of software. Standards have been adopted 
Q which specify different types of SCSI buses, e.g. the SCSI-1 and, SCSI- 11 standards. A key 

object of the SCSI- II standard is providing compatibility with those SCSI-1 devices that support 
bus parity, and that conform to level 2 of the SCSI-1 standard. In practical terms such 
compatibility means many different SCSI-1 devices operate properly if connected to a SCSI- II 
20 bus despite differences between the SCSI-1 and SCSI- II standards. 

The SCSI bus is a parallel, multimaster I/O bus which has been widely adopted for use in 
digital computer systems since the American National Standards Institute ("ANSI") approved the 
SCSI-1 standard. The first SCSI standard, now known as SCSI-1, was adopted in 1986. A 
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SCSI-1 bus interconnects at speeds of 5 MB/sec up to 8 logical units, i.e. host bus adapters or 
peripheral controllers, each unit can, in turn, have up to 8 logical subunits for a total of 64 logical 
subunits. 

Since that time, SCSI has been refined and extended numerous times, with the 
5 introduction of Fast SCSI (SCSI-2) at lOMB/sec, Fast Wide SCSI (SCSI-2), running at 
20MB/sec., and Ultra SCSI (SCSI-3 or Fast-20), which provide data transfer rates of up to 
40MB/sec. Overall, SCSI performance has doubled approximately every five years since the 
original standard was released in 1986, and the number of devices permitted on a single bus has 
been increased to 16. At the same time, a large measure of backward compatibility has been 
QO achieved, enabling newer devices to coexist on a bus with older devices. 

Ti Electrically, SCSI bus signal lines connecting devices can be either single-ended, wherein 

^ each signal's logic level is determined in relationship to a common electrical ground, or 

differential, wherein each signal's logic level is determined between pairs of conductors without 
Q reference to a common electrical ground.. A single-ended SCSI bus may be up to 18 feet long. 
N 5 Alternatively, a differential SCSI bus may be up to 75 feet long. 

H The SCSI-2 standard, which evolved from the SCSI-1 standard, makes numerous changes 

from the SCSI-1 standard including establishment of a standard way for powering SCSI bus 
terminators, and two optional performance enhancements to increase the amount of data which 
can be transferred across a SCSI-2 bus during an interval of time. These two optional 
20 performance enhancements are fast SCSI which permits up to 10,000,000 transfers across the 
bus per second, and "wide" SCSI which permits parallel transfer of either 16 or 32 bits at a time 
as an alternative to the SCSI-1 limitation of transferring only 8 bits in parallel at any instant in 
time. 
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Each SCSI bus device that includes its own separate enclosure includes two SCSI bus 
connectors, unless the device is specifically designed for connection at only the end of the SCSI 
bus. If such a two connector SCSI bus device connects to one end or the other of the bus, a SCSI 
bus cable connects to one or the other of these connectors. If the device has an internal 
terminator which generally can be enabled by a switch, usually located on the outside of the 
device's enclosure, nothing connects to the device's second connector. Conversely, if the device 
lacks an internal terminator, a SCSI bus terminator will be installed on the device's second 
connector. If a SCSI device having two connectors is installed anywhere along the length of the 
bus other than at an end of the bus, then different SCSI bus cables connect to each of the 
connectors. In this way, the SCSI bus electrically "daisy chains" through all the devices 
connected to the bus except those devices connected at one end or the other of the SCSI bus. 

To provide host bus adapters capable of fully exploiting the range of device capabilities 
permitted by the SCSI-2 standard, terminators in modem SCSI bus host bus adapters must be 
configurable to work properly when connected to devices designed for use with either the 
"narrow" SCSI-1 bus, which transfers only 8 bits at any instant in time, or with the "wide" SCSI- 
2 bus, which transfers 16 bits at each instant in time. 

Moreover, most host bus adapters also include at least two SCSI connectors, one for 
connecting to SCSI devices within the same enclosure as the host bus adapter, and another for 
connecting to SCSI devices residing in a separate enclosure. Consequently, the SCSI-2 bus 
standard permits connecting wide SCSI devices to one of a host bus adapter's connectors and 
narrow SCSI devices to another connector of the host bus adapter. Moreover, even if a host bus 
adapter provides only wide SCSI bus connectors, SCSI bus cables are available which mate with 
the wide SCSI bus connector at one end, while the cable's other end mates with a narrow SCSI 
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bus connector of a narrow SCSI bus device. Under any of these circumstances, the host bus 
adapter may be electrically located in the middle of a narrow SCSM bus while concurrently 
being located at one end of the additional signal lines of a wide SCSI-2 bus. If this occurs, the 
SCSI bus host bus adapter must be capable of providing proper termination for that portion of the 
5 wide SCSI-2 bus which exceeds the narrow SCSI-1 bus. 

A SCSI bus host bus adapter may, and frequently does, include more than two SCSI 
connectors to facilitate connecting to both narrow and wide SCSI bus cables. For example, the 
host bus adapter may include a wide SCSI-2 connector for connecting to SCSI devices residing 
in an enclosure separate from that in which the host bus adapter resides, and a pair of connectors 

rH) for connecting to SCSI devices located within the same enclosure as the host bus adapter. 

m Because a SCSI bus must be terminated, and because a SCSI bus may have only two terminators; 

N only two connectors of a host bus adapter having three or more connectors may be connected to 

5=^; devices only by one or by two connectors with any additional connectors remaining unused. 

To permit configuring the terminators included in a host bus adapter properly for its 

2J location either at one end or intermediate the ends of a SCSI bus, and/or for concurrent operation 

p both with narrow and with wide SCSI bus devices regardless of its location along the SCSI bus; 
host bus adapters frequently include switches or jumpers which, prior to operating the host bus 
adapter, must be adjusted to accommodate the actual configuration of SCSI devices included in a 
computer system. Since a host bus adapter manufacturer cannot adjust the adapter's switches or 

20 jumpers, that task must be left to the individual who configures, or re-configures, a digital 
computer system that includes a SCSI host bus adapter. 

Fibre Channel ("FC") is an industry-standard, high-speed serial data transfer interface 
that can be used to connect systems and storage in point-to-point or switched topologies. Fibre 
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Channel Arbitrated Loop (FC-AL), developed with storage connectivity in mind, is a recent 
enhancement to the standard that supports copper media and loops containing up to 126 devices, 
or nodes. FC-AL loops are hot-pluggable and tolerant of failures. 

The FC standard supports bandwidths of 133 Mb/sec, 266 Mb/sec, 532 Mb/sec, 1.0625 
Gb/sec, and 4 Gb/sec. (proposed) at distances of up to ten kilometers. Gigabit Fibre Channel's 
maximum data rate is 100 MB/sec. (200 MB/sec. full-duplex) after accounting for overhead. 

In addition to its strong channel characteristics, Fibre Channel also provides powerful 
networking capabilities, allowing switches and hubs to enable the interconnection of systems and 
storage into tightly-knit clusters. These clusters will be capable of providing high levels of 
performance for file service, database management, or general purpose computing. Because it is 
able to span up to 10 kilometers between nodes, Fibre Channel will allow the very high speed 
movement of data between systems that are greatly separated from one another. 

The FC standard defines a layered protocol architecture consisting of five layers, the 
highest defining mappings from other communication protocols onto the FC fabric. The various 
SCSI-1, -2, and -3, protocols discussed above may be mapped onto the FC fabric. 

While the preceding specifications regarding SCSI /FC buses and bus termination is 
readily understood by those who design I/O devices and host bus adapters, system users may not 
comprehend the principles required for properly adjusting the switches or jumpers included in a 
host bus adapter. Moreover, the choice between singled ended and differential cabling for SCSI 
devices adds yet another complexity which must be addressed by someone configuring a digital 
computer system that includes a SCSI host bus adapter. The potential for confusion is increased 
by the fact that cables which visually appear identical may, in fact, be quite different electrically 
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with one cable being useful only with a single-ended SCSI bus devices while the other cable 
being useful with either a single-ended or a differential SCSI bus devices. 

Therefore, the complexity of properly terminating a SCSI bus combined with the 
complexity of selecting and properly installing the right SCSI cable frequently causes great 
difficulty for individuals configuring, or re-configuring, digital computer systems that include a 
SCSI bus. Such difficulties can be particularly exasperating if the system user lacks suitable and 
comparatively expensive SCSI bus diagnostic equipment that might assist in resolving precisely 
why a data storage and retrieval system that includes a SCSI bus fails to operate properly, or to 
operate at all. 

Summary of the Invention 

Applicants' invention includes a method to validate the configuration of Applicants' data 
storage and retrieval system. Applicants' method includes the steps of mapping the one or a 
plurality of input/output devices, generating an apparent system configuration, comparing that 
apparent system configuration with each of the known valid system configurations, and 
assigning one of those known valid system configurations. 

Applicants' method further includes an embodiment wherein the selected system 
configuration is used to evaluate the performance of each I/O device connected to a host computer, 
and to evaluate the performance of each bus disposed within Applicants' system. This embodiment 
includes the steps of providing to each I/O device via one or more buses, singly or in combination, 
third information comprising a series of connect, disconnect, and data transfer commands; receiving 
fourth information from each I/O device via one or more buses, singly or in combination; analyzing 
that fourth information; and evaluating the performance of each I/O device and each interconnecting 
bus disposed within Applicants' system. 
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Applicants' invention further includes a data storage and retrieval system comprising at 
least one host computer, one or more input/output devices, at least one communication bus 
connecting the host computer to each of the one or more input/output devices, and first 
information comprising one or more known valid system configurations. Applicants' data 
5 storage and retrieval system further includes a computer useable medium having computer 
readable program code disposed therein for implementing Applicants' method to validate the 
configuration of the data storage and retrieval system. 

Applicants' invention further includes a computer program product usable with a 
programmable computer processor having computer readable program code embodied therein for 
IE) validating the configuration of a data storage and retrieval system. In certain embodiments of 
ri Applicants' invention, Applicants' computer program product further includes computer 

readable program code embodied therein for evaluating the performance of each I/O device and 
yj each interconnecting bus disposed within Applicants' system. 
Q Brief Description of the Drawings 

145 . The invention will be better understood from a reading of the following detailed description 

O taken in conjunction with the drawings in which like reference designators are used to designate like 
elements, and in which: 

FIG. I is a block diagram showing the components of a typical data storage and retrieval 

system; 

20 FIG. 2 is a block diagram showing the interconnectivity of a data storage and retrieval 

system which includes four host bus adapters and ten input/output devices; 

FIG. 3 is a flow chart summarizing the steps in Applicants' method to assign a valid 
configuration to a data storage and retrieval system; 
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FIG. 4 is a flow chart summarizing additional steps in Applicants' method to assign a valid 
configuration to Applicants' data storage and retrieval system; 

FIG. 5 is a flow chart summarizing the steps in Applicants' method to evaluate using the 
selected system configuration the performance of each I/O device disposed within Applicants' data 
5 storage and retrieval system; and 

FIG. 6 is a flow chart summarizing the steps in Applicants' method to evaluate using the 
selected system configuration the performance of each bus disposed within Applicants' data storage 
and retrieval system. 

Detailed Description Of The Preferred Embodiments 

pi 0 Turning to FIG. 1 , data storage and retrieval system 100 includes host computer 110, first 

B library 130, second library 190, first standalone I/O device 140, and second standalone I/O device 
/J 170. Host computer 1 10 includes I/O devices 112, 114, 116, and 118. Such I/O devices include, 
f^, keyboards, pointing devices, scanners, disk drives, CD-ROM drives, printers, display monitors, 
^ local area network (LAN) adapters, FAX/modem boards, sound boards, Digital Audio Tape 
litis ("DAT") drives, optical storage drives, printers, scanners, photo-composers, and the like. 
O In certain embodiments, some or all of devices 112, 114, 116, and 1 18 comprise multi- 

ported devices which are capable of interconnecting to a plurality of communication buses. In 
certain embodiments, device 1 16 comprises a visual display device. In certain embodiments, device 
1 18 comprises a printer. 

20 First library 130 includes I/O devices 132 and 134. First library includes a plurality of data 

storage media disposed in a plurality of portable data storage cartridges which are stored in a 
plurality of storage slots. One or more robotic accessors retrieve, transport, and insert these portable 
data storage cartridges in one or more data storage drives, such as I/O devices 132 and/or 134, 
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located within first library 130. U.S. Pat. No, 5,956,301 teaches such an automated data storage 
library and is hereby incorporated by reference. 

Communication link 120 connects first library 130 and host computer 1 10. Communication 
link comprises any suitable bus communication path or paths between host computer 1 10 and 
library 130. For example, communication link 120 comprises a SCSI-1 interface, a SCSI-2 
interface, a SCSI-3 interface, a Fibre Channel interface, and combinations thereof 

Second hbrary 190 includes I/O devices 192 and 194. Second library includes a plurality of 
data storage media disposed in a plurality of portable data storage cartridges which are stored in a 
plurality of storage slots. One or more robotic accessors retrieve, transport, and insert these portable 
data storage cartridges in one or more data storage drives, such as I/O devices 1 92 and/or 1 94, 
located within first library 130. Communication link 180 connects second library 130 and host 
computer 1 10. Communication link 180 comprises any suitable bus communication path or paths 
between host computer 1 10 and library 190. For example, communication link 180 comprises a 
SCSI-1 interface, a SCSI-2 interface, a SCSI-3 interface, a Fibre Channel interface, and 
combinations thereof 

Data storage and retrieval system further includes standalone I/O devices 140 and 1 70, 
Communication links 150 and 160 connect I/O devices 140 and 170, respectively, to host computer 
1 10. Communication links 150 and 160 comprise any suitable bus communication path or paths 
between host computer 1 10 and devices 140 and 170, respectively. For example, communication 
link 150 and communication link 160 each comprise a SCSI-1 interface, a SCSI-2 interface, a SCSI- 
3 interface, a Fibre Channel interface, and combinations thereof 

Referring to FIG. 2, host computer 1 10 (FIG. 1) fiorther includes first host bus adapter 210, 
second host bus adapter 220, third host bus adapter 230, and fourth host bus adapter 240. First bus 
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410 connects first host bus adapter 210 with I/O devices 250, 260, 270, 280, and 290. First bus 
includes communication links 350, 352, 354, 356, and 358. Communication link 350 comprises 
any suitable bus communication path or paths between first host bus adapter 210 and 1/0 device 
250. For example, communication link 350 comprises a SCSI-1 interface, a SCSI-2 interface, a 
SCSI-3 interface, a Fibre Channel interface, and combinations thereof Communication link 352, in 
combination with communication link 350, comprises any suitable bus communication path or 
paths between first host bus adapter 210 and I/O device 260. For example, communication link 352 
comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 interface, a Fibre Channel interface, and 
combinations thereof 

Communication link 354, in combination with communication links 350 and 352, comprises 
any suitable bus communication path or paths between first host bus adapter 2 1 0 and I/O device 
270. For example, communication link 354 comprises a SCSI-1 interface, a SCSI-2 interface, a 
SCSI-3 interface, a Fibre Channel interface, and combinations thereof Communication link 356, in 
combination with communication links 350, 352, and 354, comprises any suitable bus 
communication path or paths between first host bus adapter 210 and I/O device 280. For example, 
communication link 356 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 interface, a 
Fibre Channel interface, and combinations thereof Communication link 358, in combination with 
communication links 350, 352, 354 and 356, comprises any suitable bus communication path or 
paths between first host bus adapter 210 and I/O device 290. For example, communication link 358 
comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 interface, a Fibre Channel interface, and 
combinations thereof 

Second bus 420 connects second host bus adapter 220 with I/O devices 250, 260, 270, 280, 
and 290. Second bus includes communication links 360, 362, 364, 366, and 368. Communication 
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link 360 comprises any suitable bus communication path or paths between second host bus adapter 
220 and 1/0 device 250. For example, communication link 360 comprises a SCSI-1 interface, a 
SCSI-2 interface, a SCSI-3 interface, a Fibre Channel interface, and combinations thereof 
Communication link 362, in combination with communication link 360, comprises any suitable bus 
communication path or paths between second host bus adapter 220 and I/O device 260. For 
example, communication link 362 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 
interface, a Fibre Channel interface, and combinations thereof 

Communication link 364, in combination with communication links 360 and 362, comprises 
any suitable bus communication path or paths between second host bus adapter 220 and I/O device 
270, For example, communication link 364 comprises a SCSI-1 interface, a SCSI-2 interface, a 
SCSl-3 interface, a Fibre Channel interface, and combinations thereof Communication link 366, in 
combination with communication links 360, 362, and 364, comprises any suitable bus 
communication path or paths between second host bus adapter 220 and I/O device 280. For 
example, communication link 366 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 
interface, a Fibre Channel interface, and combinations thereof Communication link 368, in 
combination with communication links 360, 362, 364 and 366, comprises any suitable bus 
communication path or paths between second host bus adapter 220 and 1/0 device 290. For 
example, communication link 368 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 
interface, a Fibre Channel interface, and combinations thereof 

Third bus 430 connects third host bus adapter 230 with I/O devices 300, 3 10, 320, 330, and 
340. Third bus includes communication links 370, 372, 374, 376, and 378. Communication link 
370 comprises any suitable bus communication path or paths between third host bus adapter 230 
and I/O device 300. For example, communication link 370 comprises a SCSI-1 interface, a SCSI-2 
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interface, a SCSI-3 interface, a Fibre Channel interface, and combinations thereof. Conrununication 
Hnk 372, in combination with communication Hnk 370, comprises any suitable bus communication 
path or paths between third host bus adapter 230 and I/O device 310. For example, communication 
link 372 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSl-3 interface, a Fibre Channel 
interface, and combinations thereof 

Communication link 374, in combination with communication links 370 and 372, comprises 
any suitable bus communication path or paths between third host bus adapter 230 and I/O device 
320. For example, communication link 374 comprises a SCSI-1 interface, a SCSI-2 interface, a 
SCSl-3 interface, a Fibre Channel interface, and combinations thereof. Communication link 376, in 
combination with communication links 370, 372, and 374, comprises any suitable bus 
communication path or paths between third host bus adapter 210 and I/O device 330. For example, 
communication Hnk 376 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSl-3 interface, a 
Fibre Channel interface, and combinations thereof Communication link 378, in combination with 
communication links 370, 372, 374 and 376, comprises any suitable bus communication path or 
paths between third host bus adapter 230 and I/O device 340. For example, communication link 
378 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 interface, a Fibre Channel interface, 
and combinations thereof. 

Fourth bus 440 connects fourth host bus adapter 240 with I/O devices 300, 310, 320, 330, 
and 340. Fourth bus 440 includes communication links 380, 382, 384, 386, and 388. 
Communication link 380 comprises any suitable bus communication path or paths between fourth 
host bus adapter 240 and 1/0 device 300. For example, communication link 380 comprises a SCSl- 
1 interface, a SCSI-2 interface, a SCSI-3 interface, a Fibre Channel interface, and combinations 
thereof. Communication link 382, in combination with communication link 380, comprises any 
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suitable bus communication path or paths between fourth host bus adapter 240 and 1/0 device 310. 
For example, communication link 382 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 
interface, a Fibre Channel interface, and combinations thereof 

Communication link 384, in combination with communication links 380 and 382, comprises 
any suitable bus communication path or paths between fourth host bus adapter 240 and I/O device 
320. For example, communication link 384 comprises a SCSI-1 interface, a SCSI-2 interface, a 
SCSI-3 interface, a Fibre Channel interface, and combinations thereof Communication link 386, in 
combination with communication links 380, 382, and 384, comprises any suitable bus 
communication path or paths between fourth host bus adapter 240 and I/O device 330. For 
example, communication link 386 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 
interface, a Fibre Channel interface, and combinations thereof Communication link 388, in 
combination with communication links 380, 382, 384 and 386, comprises any suitable bus 
communication path or paths betAveen fourth host bus adapter 240 and I/O device 340. For 
example, communication link 388 comprises a SCSI-1 interface, a SCSI-2 interface, a SCSI-3 
interface, a Fibre Channel interface, and combinations thereof 

Host computer 110 includes first information which comprises one or more system 
configurations which are known to be "valid." By a "valid configuration," Applicants mean a 
system configuration wherein all the requisite system settings and parameters, such as device 
identifiers, device switches, device protocols, system interrupts, and the like, are set such that the 
performance of each I/O device connected to the system is acceptable. In certain embodiments, this 
first information includes nominal performance specifications for certain 1/0 devices and 
interconnecting buses. 

In certain embodiments,- this first information is encoded in read-only, non-volatile memory 
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^ disposed within host computer 110. In alternative embodiments, this first information is encoded 

within host computer 1 10 such that any modifications to such first information requires entry of one 
or more authorizing passwords. 

The initial steps in Applicants' method to validate a system configuration for a data storage 
5 and retrieval system are shown in FIG. 3. Apphcants' method begins at step 510, Step 5 10 is 
automatically invoked upon system start-up. In addition, the system user can initiate a call in step 
510 to vahdate the system configuration. In step 520, the host computer 1 10 (FIG. 1) maps all I/O 
' devices, such as devices 1 12, 1 14, 132, 134, 140, 192, and 194 (FIG. 1), connected to host computer 
1 10. Step 520 further includes step 522 wherein host computer 1 10 sends a query to each connected 
OO I/O device via each bus connected to host computer 1 10, such as first bus 410, second bus 420, third 

^ bus 430, and fourth bus 440 (FIG. 2). 

W 

In step 524, host computer 1 10 receives second information from each I/O device on the 

lii 

Tjl system. This second informafion includes the identity of each reporting I/O device, the location of 
Q each I/O device, the type of each I/O device, certain anficipated performance characteristics of each 
Mi 5 I/O device, and the connectivity of each I/O device, i.e. which one or more buses interconnect with 
□ each I/O device. 

In step 530, host computer 1 10 generates an apparent system configuration based upon the 
second information received from the various I/O devices responding to the query call. This 
apparent system configuration includes the total number "h" of 1/0 devices responding, and ihc lotal 
20 number "i" of operafive buses. 

In step 540, host computer 1 10 compares the apparent system configuration with the first 
informafion to determine if the apparent configuration matches one of the known valid system 
configurafions. In making this comparison, host computer 1 10 matches the data points comprising 
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the apparent configuration, i.e. the number of I/O devices found, the number of buses found, the 
identities of each device found, and the identities of each operative port of each I/O device, to a 
table of one or more known valid configurations. If, for example, a known valid configuration 
included ten (10) data points and an apparent configuration included eight (8) of those data points. 
5 the comparison between the apparent configuration and the known valid configuration would retum 
an eighty percent (80%) match. 

In certain embodiments, host computer includes one or more visual display devices, such as 
visual display device 1 16 (FIG. 1). If the apparent configuration matches a known valid 
configuration, then in step 560 host computer 110 displays the apparent system configuration. In 
pi 0 certain embodiments, host computer 1 10 visually displays in text form the apparent system 
W configuration on visual display device 116 (FIG. 1). In certain embodiments, host computer 1 10 

H * j 

displays the apparent system configuration in a graphical form on visual display device 116. In 
rj certain embodiments, host computer 1 10 prints the apparent system configuration in text form using 
printer 1 18 (FIG. 1). In certain embodiments host computer 1 10 prints the apparent system 

y,l 5 configuration in graphical form using printer 1 1 8. 

fn 

p If the apparent configuration does not match a known valid configuration, then in step 570 

host computer 1 10 assigns one of the one or more known valid configurations as the operative 
system configuration. That selected configuration comprises the best match between the apparent 
system configuration and the known valid systems configurations. In steps 580 and 590, host 
20 computer 1 10 displays the apparent system configuration and the operative system configuration. 

In certain embodiments, host computer 1 10 visually displays in text form the apparent 
system configuration and the selected system configuration on visual display device 116 (FIG. 1). 
In certain embodiments, host computer 1 10 displays in graphical form the apparent system and the 
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selected system configuration on visual display device 116. In certain embodiments, host computer 
1 10 prints in text form the apparent system configuration and the selected system configuration 
using printer 118 (FIG. 1). In certain embodiments host computer 1 10 prints in graphical form the 
apparent system configuration and the selected system configuration using printer 1 18. 

In step 600, host computer 1 10 determines if one or more I/O devices are inoperative under 
the selected system configuration. In the event host computer 1 10 determines there are no 
inoperative I/O devices under the selected configuration, then Applicants' method loops to step 710 
wherein host computer 1 10 evaluates the performance of each I/O device using the selected system 
configuration. 

On the other hand, if host computer 1 10 determines there are one or more inoperative I/O 
devices using the selected system configuration, then in step 610 (FIG. 4) host computer 1 10 
displays one or more error messages. Such error messages are visually displayed in text form using 
display device 1 16 (FIG. 1), and/or printed in text form using printer 1 1 8 (FIG. 1). 

In step 620, host computer 1 10 examines its first information to determine whether that first 
information includes an alternate valid system configuration that includes the I/O devices 
inoperative under the selected configuration. If host computer 1 10 finds no such altemative valid 
configuration, then Applicants' method loops to step 710 wherein host computer 1 10 evaluates the 
performance of each operative I/O device and bus disposed within the system. On the other hand, if 
host computer 1 10 determines that an altemative valid configuration exists which includes the 
presently-inoperative I/O devices, then in step 630 host computer 1 10 displays/prints one or more 
correction messages identifying that altemative valid configuration and instructions to modify the 
current apparent configuration to match that altemative valid configuration. 

In step 640, host computer 1 10 queries the user to determine if the user modified the present 
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apparent configuration. In the event the user elects not to modify the present apparent configuration 
to match an alternative valid configuration, then Applicants' method loops to step 710 wherein host 
computer 1 10 evaluates using the selected system configuration the performance of each operative 
I/O device and bus. If, however, the user indicates that the present apparent system configuration 
was modified, then Applicants' method loops to step 520 to validate the modified system 
configuration. 

Refemng now to FIGs. 5 and 6, after selecting and invoking a known valid system 
configuration host computer 1 10 (FIG. 1) then evaluates the performance of each of the h I/O 
devices, and evaluates the performance of defined portions of each of the m buses, operational 
under the selected system configuration. In step 720, host computer 1 10 evaluates the performance 
of a designated I/O device, such as I/O device 250 (FIG. 2) using the selected system configuration. 
In step 820, host computer 1 10 evaluates the performance of a host bus adapter 210 and 
communication link 350. 

In evaluating the performance of 1/0 device 250 and its interconnection to the system, host 
computer 1 10 stresses 1/0 device 250 and the interconnections between device 250 and host 
computer 1 10, i.e. first host bus adapter 210 (FIG. 2), second host bus adapter 220, communication 
link 350, and communication link 360. By "stressing" these components, Applicants mean that host 
computer 1 10 provides third information to device 250 via first bus 410 and/or second bus 420, and 
receives fourth information from device 250 via first bus 410 and/or second bus 420, using the 
maximum data transfer rate possible under the selected system configuration. 

Third information comprises a mixture of commands to evaluate the performance of device 
250, first bus 410, and second bus 420 during all phases of device/bus operation. As those skilled in 
the art will appreciate, these phases include arbitration of conflicting device requests for bus access, 
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device/bus selection, data transfer, command transmission and reception, and message transmission 
and reception. 

Third information includes, for example, a series of connect commands interspersed with a 
series of disconnect commands. By connect commands, Applicants mean commands that do not 
require the I/O device to disconnect from the bus. Such connect commands include read buffer 
commands, write buffer commands, and other data transfer commands. As those skilled in the art 
will appreciate, read/write buffer commands do not require media to be loaded. 

By disconnect commands, Applicants mean commands that cause an I/O device to 
disconnect, assemble data, reconnect, and communicate that data. Such discormect commands 
include log sense commands, mode sense commands, and the like. Those skilled in the art will 
appreciate that log sense commands comprise control commands that cause an 1/0 device to retrieve 
data regarding that device's performance. Mode sense commands comprise control commands that 
causes a device to report its current settings. 

Fourth information includes device status information, transmitted data, bus access requests, 
and the like. In step 720, host computer 1 10 provides third information to device 250, and receives 
fourth information from device 250, using first host bus adapter 210 (FIG. 2) and first bus 410 (FIG. 
2) for first time period PI beginning at a first fime Tl and ending at a second time T2. Applicants 
have found that the duration of this first time period should be at least ten seconds. 

Host computer 1 10 then provides fifth information to, and receives sixth information from, 
device 250 using second host bus adapter 220 (FIG. 2) and link 360 for second time period P2 
beginning at a third time T3 and ending at a fourth time T4. The durafion of second time period P2 
is at least ten seconds. 

Applicants have found that a ten second durafion for first time period PI and second time 



TUC9 2001 0028US1 



19 



period P2 is sufficient to evaluate the performance of most I/O devices and interconnecting buses. 
In certain circumstances, however, a longer evaluation period is needed. Therefore, in certain 
embodiments of Applicants' method the durations of first time period PI and second time period P2 
are user programmable. 

5 Host computer 1 10 then simultaneously provides third and fifth information to, and receives 

fourth and sixth information from, device 250 using first host bus adapter 2 1 0/link 350 and second 
host bus adapter 220/link 360, respectively. During a third time period P3, first time period PI is 
adjusted to coincide with second time period P2, i.e. first time Tl equals third time T3 and second 
time T2 equals fourth time T4. In certain embodiments, the duration of third time period P3 is 
IJD about ten seconds. During a fourth time period P4, first time period P 1 is adjusted to partially 
S overlap with second time period P2. 

In step 720 host computer 1 10 analyzes the fourth information received during first time 
'r: period PI , the sixth information received during second time period P2, the fourth and sixth 
Q information received during third time period P3, and the fourth and sixth information received 
fi5 during fourth time period P4. Based upon that analysis, in step 720 host computer 1 10 generates 
O seventh information comprising a quantification of the performance of I/O device 250. 

In step 730, host computer 1 10 compares seventh information to first information and/or 
second information comprising nominal performance specifications for device 250. In the event the 
performance of device 250 is determined to be unacceptable in step 740, then in step 760 host 
20 computer 1 10 displays an error message regarding that unacceptable performance. In certain 

embodiments, the first information resident in host computer 1 10 includes one or more corrective 
actions that can be taken to enhance the performance of device 250. In these embodiments host 
computer 1 10 in step 770 displays one or more correction messages. In step 780, host computer 
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1 10 ascertains if the user elected to replace or modify device 250. In the event the user replaces or 
modifies device 250, then Applicants' method loops to step 720 and again evaluates the 
perfomiance of that modified/replaced device. 

On the other hand, if the user elects not to repair/replace device 250 in step 780, or in the 
5 event the performance of device 250 is determined to be acceptable in step 740, host computer 1 10 
then determines whether the performance of each of the I/O devices has been evaluated. The 
performance of each individual I/O device operational under the selected system configuration is 
evaluated using the method summarized in FIG. 5. 

Referring again to FIG. 6, in step 820 host computer 1 10 provides third information via first 
QO bus 410 to all the I/O devices interconnected to first bus 410, and receives fourth information from 
w all those 1/0 devices interconnected to first bus 410. Host computer 1 10 also provides fifth 
/"•^ information via second bus 420 to all the I/O devices interconnected to second bus 420, and receives 
?^ sixth information from all those 1/0 devices interconnected to second bus 420. Host computer 1 10 
^5 then generates eighth information comprising a quantification of the performance of first bus 410, 
Cd 5 and ninth information comprising a quantification of the performance of second bus 420, 
Q In step 830, host computer 1 10 compares eighth information to first information and/or 

second information comprising nominal performance specifications for first bus 410. In the event 
the performance of first bus 410 is determined to be unacceptable in step 840, then in step 850 host 
computer 1 10 displays an error message regarding that unacceptable pertbrmance. In certain 
20 embodiments, first information resident in host computer 1 10 includes one or more corrective 
actions that can be taken to enhance the performance of first bus 410. In these embodiments host 
computer 1 10 in step 860 displays one or more correction messages. In step 870, host computer 
1 10 ascertains if the user elected to modify first bus 410, In the event the user modifies first bus 
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410, then Applicants' method loops to step 820 and again evaluates the performance of that 
modified first bus 410. 

On the other hand, if the user elects not to modify first bus 410 in step 870, or in the event 
the performance of first bus 410 is determined to be acceptable in step 840, host computer 1 10 then 
determines whether the performance of each of the m buses have been evaluated. The performance 
of each bus operational under the selected system configuration is individually evaluated using the 
method summarized in FIG. 6. 

After the performance of each of the I/O devices operational under the selected system 
configuration is individually validated in accord with Applicants' method summarized in FIG. 5, 
and after the performance of each of the interconnections operational under the selected system 
configuration is individually validated in accord with Applicants' method summarized in FIG. 6, 
Applicants' data storage and retrieval system is placed in a fiilly operafional ready mode in step 900. 

While the preferred embodiments of the present invention have been illustrated in detail, it 
should be apparent that modifications and adaptations to those embodiments may occur to one 
skilled in the art without departing from the scope of the present invention as set forth in the 
following claims. 
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